﻿<!DOCTYPE HTML>
<html lang="zh">
<head>
<title>WinClose - 语法 &amp; 使用 | AutoHotkey v2</title>
<meta name="description" content="The WinClose function closes the specified window." />
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<link href="../static/theme.css" rel="stylesheet" type="text/css" />
<script src="../static/content.js" type="text/javascript"></script>
<script type="text/javascript">$(function(){0<=window.navigator.userAgent.toLowerCase().indexOf("ucbrowser")&&CaoNiMaDeUc()})</script>
</head>
<body>

<h1>WinClose</h1>

<p>关闭指定的窗口.</p>

<pre class="Syntax"><span class="func">WinClose</span> <span class="optional">WinTitle, WinText, SecondsToWait, ExcludeTitle, ExcludeText</span></pre>
<h2 id="Parameters">参数</h2>
<dl>

  <dt>WinTitle</dt>
  <dd>
    <p>类型: <a href="../Concepts.htm#strings">字符串</a>, <a href="../Concepts.htm#numbers">整数</a>或<a href="../Objects.htm">对象</a></p>
    <p>识别目标窗口的窗口标题或其他条件. 请参阅 <a href="../misc/WinTitle.htm">WinTitle</a>.</p>
  </dd>

  <dt>WinText</dt>
  <dd>
    <p>类型: <a href="../Concepts.htm#strings">字符串</a></p>
    <p>如果存在, 此参数必须是目标窗口的单个文本元素的子字符串(和内置的 Window Spy 工具显示的一样). 如果 <a href="DetectHiddenText.htm">DetectHiddenText</a> 为 ON, 那么会检测隐藏文本元素.</p>
  </dd>

  <dt>SecondsToWait</dt>
  <dd>
    <p>类型: <a href="../Concepts.htm#numbers">整数</a>或<a href="../Concepts.htm#numbers">浮点数</a></p>
    <p>如果省略或为空, 此函数不会等待. 如果为 0, 则它会等待 500ms. 否则, 它会等待指定的秒数(可以为小数或<a href="../Variables.htm#Expressions">表达式</a>) 来让窗口关闭. 如果窗口在此期间没有关闭, 那么脚本会继续执行. 当函数处于等待状态时, 可以通过<a href="../Hotkeys.htm">热键</a>, <a href="../objects/Menu.htm">自定义菜单项</a>或<a href="SetTimer.htm">计时器</a>来启动新的<a href="../misc/Threads.htm">线程</a>.</p>
  </dd>

  <dt>ExcludeTitle</dt>
  <dd>
    <p>类型: <a href="../Concepts.htm#strings">字符串</a></p>
    <p>标题中含有此参数值的窗口将被排除.</p>
  </dd>

  <dt>ExcludeText</dt>
  <dd>
    <p>类型: <a href="../Concepts.htm#strings">字符串</a></p>
    <p>文本中含有此参数值的窗口将被排除.</p>
  </dd>

</dl>

<h2 id="Error_Handling">错误处理</h2>
<p>如果找不到窗口, 则抛出异常, 除非使用了 <a href="#group">group</a> 模式.</p>
<p>如果找到了一个窗口但无法关闭, 则不会抛出异常, 因此, 如果你需要确定窗口已经关闭, 请使用 <a href="WinExist.htm">WinExist</a> 或 <a href="WinWaitClose.htm">WinWaitClose</a>.</p>

<h2 id="Remarks">备注</h2>
<p>此函数发送关闭消息到窗口. 结果取决于窗口(它可能会询问是否保存数据等).</p>
<p>如果匹配窗口是活动的, 那么会优先关闭此窗口而不是其他匹配窗口. 一般而言, 如果有多个匹配窗口, 那么会关闭最上面的(最近使用的) 窗口.</p>
<p id="group">>此函数仅对单独一个窗口起作用, 除非 <em>WinTitle</em> 是 <a href="GroupAdd.htm">ahk_group GroupName</a>(没有其他指定条件), 在这种情况下, 组中的所有窗口均会受到影响.</p>
<p>WinClose 发送 WM_CLOSE 消息到目标窗口, 这种关闭方法有些强制性. 关闭窗口的另一种方法是发送下面的消息. 它可能会产生与此命令不同的行为, 因为它类似于按下 <kbd>Alt</kbd>+<kbd>F4</kbd> 或点击窗口标题栏的关闭按钮的效果:</p>
<pre>PostMessage 0x112, 0xF060,,, <i>WinTitle</i>, <i>WinText</i>  <em>; 0x112 = WM_SYSCOMMAND, 0xF060 = SC_CLOSE</em></pre>
<p>如果使用 WinClose 无法关闭窗口, 那么您可以使用 <a href="WinKill.htm">WinKill</a> 来强制关闭.</p>
<p>窗口标题和文本是区分大小写的. 除非 <a href="DetectHiddenWindows.htm">DetectHiddenWindows</a> 被打开, 否则不会检测隐藏窗口.</p>
<h2 id="Related">相关</h2>
<p><a href="WinKill.htm">WinKill</a>, <a href="WinWaitClose.htm">WinWaitClose</a>, <a href="ProcessClose.htm">ProcessClose</a>, <a href="WinActivate.htm">WinActivate</a>, <a href="SetTitleMatchMode.htm">SetTitleMatchMode</a>, <a href="DetectHiddenWindows.htm">DetectHiddenWindows</a>, <a href="../misc/WinTitle.htm#LastFoundWindow">Last Found Window</a>, <a href="WinExist.htm">WinExist</a>, <a href="WinActive.htm">WinActive</a>, <a href="WinWaitActive.htm">WinWaitActive</a>, <a href="WinWait.htm">WinWait</a>, <a href="GroupActivate.htm">GroupActivate</a></p>
<h2 id="Examples">示例</h2>
<div class="ex" id="ExBasic">
<p><a href="#ExBasic">#1</a></p>
<pre>if WinExist("Untitled - Notepad")
    WinClose <em>; 使用上面找到的窗口</em>
else
    WinClose "Calculator"</pre>
</div>

</body>
</html>